

#### **CLAIMS**

6

7

8

9

10

11

12

13

14

15

16

17

18

19

1

2

3

4

5

6

1. A multiprocessor computer system having a plurality of processors interconnected so that they can share memory, comprising:

a plurality of links, each link of said plurality of links connecting a processor to another processor;

a router box (RBOX) associated with each processor of said plurality of processors, said RBOX arranged to forward a message received on an input link of said plurality of links from a source processor to an outgoing link of said plurality of links toward a destination processor in response to data carried in said message;

a plurality of microprocessors, each of said microprocessors having a microprocessor memory associated therewith, a selected microprocessor of said plurality of microprocessors associated with at least one processor of said plurality of processors, said plurality of microprocessors arranged to control said plurality of processors, said control including applying electric power to a selected processor and removing electric power from said selected processor;

a data structure stored in microprocessor memory, said data structure storing a representation of the links connecting said processors and storing routes used by said RBOX in routing messages along said links, a copy of said data structure stored in microprocessor memory of each of said microprocessors; and,

a process to update said data structure in each said microprocessor memory in the event that a change occurs in a status of a component of said multiprocessor computer system.

2. The apparatus of claim 1 further comprising:

a process executing in said microprocessors for directing said microprocessors in formation of a partition of said processors, said partition having a selected number of said processors as members, said members capable of reading and writing a common memory within said partition, and other non-member processors excluded from reading and writing said common memory; and,

7

8

9

ı

2

3

4

5

6

7

8

9

10

2

3

4

5

6

7

8

1

2

3

4

5

6

a second data structure for storing a representation of said partitions, and storing routes through said links for transfer of messages between processors within a partition but not between processors of different partitions.

# 3. The apparatus of claim 2 further comprising:

a management computer communicating through said local area network with said microprocessors, said management computer having an input device such as a keyboard and mouse for entering commands to said plurality of microprocessors to modify said data base in order to establish the processors belonging to a partition, said multiprocessor computer system supporting a plurality of said partitions;

a process responsive to said data base, said process executing in said microprocessors to establish that a processor in a partition can read and write memory associated with other processors of said partition, but cannot read and write memory associated with processors which are not members of said partition.

### 4. The apparatus of claim 1 further comprising:

an input/output (IO) subsystem associated with selected processors of said plurality of processors;

an IO microprocessor associated with each said IO subsystem, said IO microprocessor communicating with said microprocessors through said local area network, each said IO microprocessor having an IO microprocessor memory holding a copy of said database;

a process executing in said IO microprocessor, said process responsive to said database, said process to apply power or remove power to said IO subsystem.

### 5. The apparatus of claim 1 further comprising:

a boot-up process executing in microprocessors of said plurality of microprocessors, said boot-up process to start execution of said processors of said multiprocessor system, and said multiprocessor system capable of continuing operation, after start of execution of said processors, to permit removal of a microprocessor from the multiprocessor system without interrupting execution of said processors.

1

2

3

4

5

6

. 7

8

9

10

11

12

13

14

15

16

17

18

1

2

3

4

5

6

7

8

9

1

6. A method for operating a multiprocessor computer system, comprising:

connecting a plurality of processors so that they can share memory, a processor of said plurality of processors connected to another processor by at least one link of a plurality of links;

associating a router box (RBOX) with each processor of said plurality of processors, said RBOX arranged to forward a message received on an input link of said plurality of links from a source processor to an outgoing link of said plurality of links toward a destination processor in response to data carried in said message;

interconnecting a plurality of microprocessors, each of said microprocessors having a microprocessor memory associated therewith, a selected microprocessor of said plurality of microprocessors associated with at least one processor of said plurality of processors, said plurality of microprocessors arranged to control said plurality of processors, said control including applying electric power to a selected processor and removing electric power from said selected processor;

storing a data structure in microprocessor memory, said data structure storing a representation of the links connecting said processors and storing routes used by said RBOX in routing messages along said links, a copy of said data structure stored in microprocessor memory of each of said microprocessors; and,

updating said data structure in each said microprocessor memory in the event that a change occurs in a status of a component of said multiprocessor computer system.

## 7. The method of claim 6, further comprising:

executing a process in said microprocessors for directing said microprocessors in formation of a partition of said processors, said partition having a selected number of said processors as members, said members capable of reading and writing a common memory within said partition, and other non-member processors excluded from reading and writing said common memory; and,

storing in a second data structure a representation of said partitions, and storing routes in said second data structure through said links, said routes for transfer of messages between processors within a partition but not between processors of different partitions.

## 8. The method of claim 6, further comprising:

establishing communication between a management computer and said microprocessors
through said local area network, said management computer having an input device such as a
keyboard and mouse for entering commands to said plurality of microprocessors to modify said
data base in order to establish the processors belonging to a partition, said multiprocessor computer system supporting a plurality of said partitions;
establishing, in response to said data base, that a processor in a partition can read and

establishing, in response to said data base, that a processor in a partition can read and write memory associated with other processors of said partition, but cannot read and write memory associated with processors which are not members of said partition.

9. The method of claim 6, further comprising:

associating an input/output (IO) subsystem with selected processors of said plurality of processors;

associating an IO microprocessor with each said IO subsystem, said IO microprocessor communicating with said microprocessors through said local area network, each said IO microprocessor having an IO microprocessor memory holding a copy of said database;

executing a process in said IO microprocessor, said process responsive to said database, said process to apply power or remove power to said IO subsystem.

10. The method as in claim 6, further comprising:

executing a boot-up process in microprocessors of said plurality of microprocessors, said boot-up process to start execution of said processors of said multiprocessor system, and said multiprocessor system capable of continuing operation, after start of execution of said processors, to permit removal of a microprocessor from the multiprocessor system without interrupting execution of said processors.